<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>矢量裁剪分析</title>
    <script type="text/javascript" include="bootstrap,jquery,loader" src="../js/include-web.js"></script>
    <script type="text/javascript" src="../../dist/include-mapboxgl.js"></script>
    <style>
        .mb-popup {
            position: absolute;
            top: 10px;
            right: 10px;
        }
    </style>
</head>
<body style=" margin: 0;overflow: hidden;background: #fff;width: 100%;height:100%;position: absolute;top: 0;">
<div id="map" style="width: 100%;height:100%"></div>
<div id="popup" class="mb-popup" style='width:350px'>
    <div class="panel panel-default">
        <div class='panel-heading'>
            <h3 class='panel-title'>矢量裁剪分析</h3>
        </div>
        <div class='panel-body'>
            <div class='input-group'>
                <span class='input-group-addon'>源数据集<span title="必填字段" style="color: red;"> * </span>　</span>
                <input id='datasetName' type='text' class='form-control'
                       value='samples_processing_newyorkZone_R'/></div>
            <p></p>
            <div class='input-group'>
                <span class='input-group-addon'>裁剪对象数据集<span title="必填字段" style="color: red;"> * </span></span>
                <input id='datasetOverlay' type='text' class='form-control'
                       value='samples_processing_singleRegion_R'/>
            </div>
            <p></p>
            <div class='input-group'>
                <span class='input-group-addon'>裁剪分析模式<span title="必填字段" style="color: red;"> * </span></span>
                <select class='form-control' id='mode' name='mode'>
                    <option value='clip' selected>内部裁剪</option>
                    <option value='intersect'>外部裁剪</option>
                </select>
            </div>
            <p></p>
            <div align='right'>
                <input type='button' id='btn' class='btn btn-primary' value='创建'/>
            </div>
        </div>
    </div>
</div>
<script>
    var map,
        baseUrl = (window.isLocal ? document.location.protocol + "//" + document.location.host : "http://117.122.248.69:8090") + "/iserver/services/map-world/rest/maps/World",
        mapUrl = baseUrl + "/zxyTileImage.png?z={z}&x={x}&y={y}",
        processingsUrl = (window.isLocal ? document.location.protocol + "//" + document.location.host : "http://117.122.248.69:8090") + "/iserver/services/distributedanalyst/rest/v1/jobs",
        token = 'yurnlSeWak-vh77nAh73yrW_cHDTDJrfZxCVl7-h3GhMSMSNTPjvH7ykQviXfH1tOQ2ckJtUt6J9RY32GFNa6Q..';
    var attribution = "<a href='https://www.mapbox.com/about/maps/' target='_blank'>© Mapbox </a>" +
        "| Map Data <span>© <a href='http://support.supermap.com.cn/product/iServer.aspx' target='_blank'>SuperMap iServer</a></span> " +
        " with <span>© <a href='http://iclient.supermapol.com' target='_blank'>SuperMap iClient</a></span>";

    map = new mapboxgl.Map({
        container: 'map',
        style: {
            "version": 8,
            "sources": {
                "raster-tiles": {
                    "attribution": attribution,
                    "type": "raster",
                    "tiles": [mapUrl],
                    "tileSize": 256
                }
            },
            "layers": [{
                "id": "simple-tiles",
                "type": "raster",
                "source": "raster-tiles",
            }]
        },
        center: [-73.95, 40.75],
        zoom: 11
    });
    map.addControl(new mapboxgl.NavigationControl(), 'top-left');
    map.addControl(new mapboxgl.supermap.LogoControl(), 'bottom-right');

    if (!window.isLocal) {
        SuperMap.SecurityManager.registerToken('http://117.122.248.69:8090/iserver', token);
    }
    var processingService = new mapboxgl.supermap.ProcessingService(processingsUrl);
    bindClick();

    function bindClick() {
        $('#btn').on('click', function () {
            if ($('#msg_container')[0]) {
                $('#msg_container').remove();
            }
            showLoader();
            if (map.getLayer("vectorClipLayer")) {
                map.removeLayer("vectorClipLayer");
            }
            addVectorClipJobs();
        });
    }

    function addVectorClipJobs() {
        var vectorClipJobsParameter = new SuperMap.VectorClipJobsParameter({
            datasetName: $('#datasetName').val(),
            datasetOverlay: $('#datasetOverlay').val(),
            mode: $('#mode option:selected').attr('value')
        });
        processingService.addVectorClipJob(vectorClipJobsParameter, function (serviceResult) {
            if (serviceResult.error) {
                removeLoader();
                var errorMsg = serviceResult.error.errorMsg || "code: " + serviceResult.error.code;
                showAlert("创建失败!<br>" + errorMsg, false);
                return;
            }
            serviceResult.result.setting.serviceInfo.targetServiceInfos.map(function (info) {
                if (info.serviceType === 'RESTMAP') {
                    SuperMap.FetchRequest.get(info.serviceAddress + '/maps').then(function (response) {
                        return response.json();
                    }).then(function (result) {
                        var mapUrl = result[0].path + "/zxyTileImage.png?z={z}&x={x}&y={y}&width=256&height=256&transparent=true";
                        map.addSource("vectorClipData", {
                            "type": "raster",
                            "tiles": [mapUrl],
                            "tileSize": 256
                        });
                        map.addLayer({
                            "id": "vectorClipLayer",
                            "type": "raster",
                            "source": "vectorClipData",
                            "minzoom": 0,
                            "maxzoom": 22
                        });

                        removeLoader();
                    });
                }
            });
        });
    }

    function showAlert(msg, state) {
        var className = "alert-";
        className += state ? "success" : "danger";
        if (!$('#msg_container')[0]) {
            var alertDiv = $("<div class='alert alert-dismissible' id='msg_container' role='alert' " +
                "style='z-index:800;position: absolute;top: 20px;left: 40%;width:400px;display: none'>" +
                "<button type='button' class='close' data-dismiss='alert' aria-label='Close'><span aria-hidden='true'>&times;</span></button>" +
                "<strong><p id='msg' style='word-wrap: break-word'></p></strong></div>");
            $('body').append(alertDiv)
        }
        $('#msg_container').addClass(className);
        $('#msg_container').slideDown(300);
        $('#msg').html(msg);
    }
</script>

</body>
</html>